## گزارش فاز سوم پروژه MIPS معماری کامپیوتر

هدف این فاز، تبدیل پروسسور multi cycle فاز پیشین به یک پروسسور pipelined است. این پروسسور مطابق شکل زیر، دارای پنج استیج Execution ،Instruction decode ،Instruction fetch، Write back است:



در قدم اول، قطعات مربوط به هر استیج از ماژول mips core خارج شده و در ماژولهای جداگانه به نامهای هر استیج قرار گرفته و در نهایت استیجها در فایل mips core کنار یکدیگر قرار گرفته و به هم متصل شدند. در قدم بعدی، بین هر استیج، رجیسترهای بافر برای ذخیره کردن دادههای مورد نیاز استیجهای بعدی قرار داده شدند (ماژول pipe)؛ به صورتی که هرکدام داده ورودی خود را با هر کلاک در خروجی خود قرار می دهند مگر آنکه سیگنال stall مربوط به آن pipe فعال باشد. سپس ورودیهای هر استیج، طوری تغییر داده شد که تنها از بافر مربوط به خود تغذیه شود؛ مگر در موارد jump و write back در این موارد، تمامی دادههای مورد نیاز استیج فعلی حتی اگر زودتر آماده شود، در بافرها منتقل می شود تا در زمان مناسب همراه بقیه سیگنالها به این استیج باز گردانده شود.

در قدم سوم، از آنجایی که Control unit در فاز برای دستورهای مربوط به Memory و Signal control به صورت یک بود، به ماژولهای Signal control و MA\_CU شکسته شد. ماژول ایه Signal control به صورت یک مدار combinational، سیگنالهای کنترلی که در مدت اجرای دستور نیستند را تولید می کند. سپس این سیگنالها همانند بقیه دادهها، در بافرها منتقل می شوند تا به مقصد برسند و هر استیج قابلیت استقلال از استیجهای پیشین خود را داشته باشد. ماژول MA\_CU به استیج MA\_CU منتقل شد تا کنترل قسمت مموری به درستی انجام گیرد.

در گام نهایی، به دلیل کنترل کردن اختلاف زمانی زیاد بین اجرای استیج memory با بقیه استیجها، ماژول hazard unit کند.